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A Very Long Instruction Word processor (VLIW processor) is capable of 
executing many operations within one clock cycle. Generally, a compiler reduces program 
instructions into basic operations that the processor can perform simultaneously. The 
operations to be performed simultaneously are combined into a very long instruction word 
5 (VLIW). The instruction decoder of the VLIW processor decodes and issues the basic 
operations comprised in a VLIW each to a respective processor data-path element 
Alternatively, the VLIW processor has no instruction decoder, and the operations comprised 
in a VLIW are directly issued each to a respective processor data-path element. 
Subsequently, these processor data-path elements execute the operations in the VLIW in 

10 parallel. This kind of parallelism, also referred to as instruction level parallelism (LLP), is 
particularly suitable for applications which involve a large amount of identical calculations, 
as can be found e.g. in media processing. Other applications comprising more control 
oriented operations, e.g. for servo control purposes, are not suitable for programming as a 
VLIW-program. However, often these kind of programs can be reduced to a plurality of 

1 5 program threads which can be executed independently of each other. The execution of such 
threads in parallel is also denoted as thread-level parallelism (TLP). A VLIW processor is, 
however, not suitable for executing a program using thread-level parallelism. Exploiting the 
latter type of parallelism requires that different sub-sets of processor data-path elements have 
an independent control flow, i.e. that they can access their own programs in a sequence 

20 independent of each other, e.g. are capable of independently performing conditional 

branches. The data-path elements in a VLIW processor, however, operate in a lock- step 
mode, i.e. they all execute a sequence of instructions in the same order. The VLIW processor 
could, therefore, only execute one thread. 

It is a purpose of the invention to provide a processor which is capable of 

25 using the same sub-set of data-path elements to exploit instruction level parallelism or task 
level parallelism or a combination thereof, dependent on the application. 

For that purpose, a processor according to the invention comprises a plurality 
of processing elements, the processing elements comprising a controller and computation 
means, the plurality of processing elements being dynamically reconfigurable as mutually 



>PHNL021373EPP 



2 20.12.2002 
independently operating task units, which task units comprise one processing element or a 
cluster of two or more processing elements, the processing elements within a cluster being 
arranged to execute instructions under a common thread of program control. Processing 
elements in a cluster are said to run in lock-step mode. The computation means can comprise 
adders, multipliers, means for performing logical operations, e.g. AND, OR, XOR etc, 
lookup table operations, memory accesses, etc. 

It is noted that "Architecture and Implementation of a VLIW Supercomputer" 
by Colwell et all., in Proc. of Supercomputing '90, pp. 91 0-9 19, describe a VLIW processor, 
which can either be configured as two 14-operations-wide processors, each independently 
controlled by a respective controller, or one 28-operations-wide processor controlled by one 
controller. Said document, however, neither discloses the principle of a processor array 
which can be reconfigured into an arbitrary number of independently operating clusters 
comprising an arbitrary number of processing elements, nor does it disclose how such a 
processor array could be realized. 

hi a processor array according to the present invention, the processing 
elements can operate all independently or all in lock-step mode. Contrary to the prior art, the 
invention also allows clusters of processing elements to operate independently of each other 
while the processing elements within each cluster can perform a task using instruction level 
parallelism. In this way, the processor can dynamically adapt its configuration to the most 
suitable form depending on the task. In a task having few possibilities for exploiting 
parallelism at instruction level, the processor can be configured as a relatively large number 
of small clusters (e.g. comprising only one, or a few, processing elements). This makes it 
possible to exploit parallelism at thread-level. If the task is very suitable for exploiting 
instruction level parallelism, as is often the case in media processing, the processor can be 
reconfigured to a small number of large clusters. The size of each cluster can be adapted to 
the requirements for processing speed. This makes it possible to have several threads of 
control flow in parallel, each having a number of functional units that matches the ILP that 
can be exploited in that thread. The configuration of the processor into clusters can be either 
static or dynamic. In the static case, the configuration remains the same throughout the 
application execution. In the dynamic case, it may be altered at run-time during application 
execution. The static case can be considered as a special case of the dynamic case. 

US6,266,760 describes a reconfigurable processor comprising a plurality of 
basic functional units, which can be configured to execute a particular function, e.g. as an 
ALU, an instruction store, a function store, or a program counter. In this way the processor 
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can be used in several ways, e.g. a micro-controller, a VLIW processor, or a MIMD 
processor. The document, however, does not disclose a processor comprising different 
processiftg~elements each having a controller, wherein the processing-elements can be 
configured in one or more clusters, and where processing elements within the same cluster 
5 operate under a common thread of control despite having their own controller, and wherein 
processors in mutually different clusters operate independently of each other, i.e. according 
to different threads of control. 

US6,298,430 describes a user-configurable ultra-scalar multiprocessor which 
comprises a predetermined plurality of distributed configurable signal processors (DCSP) 

10 which are computational clusters that each have at least two sub microprocessors (SM) and 
one packet bus controller (PBC) that are a unit group. The DCSPs, the SM and the PBC are 
connected through local network buses. The PBC has communication buses that connect the 
PBC with each of the SM. The communication buses of the PBC that connect the PBC with 
each SM have serial chains of one hardwired connection and one programmably-switchable 

15 connector. Each communication bus between the SMs has at least one hardwired connection 
and two programmably-switchable connectors. A plurality of SMs can be combined 
programmably into separate SM groups. All of a cluster's SM can work either in an 
asynchronous mode, or in a synchronous mode, when clocking is made by a clock frequency 
from one SM in the cluster, which serves as the master. The known multi processor does not 

20 allow a configuration in clusters of an arbitrary size. 

The processing elements preferably each have their own instruction memory, 
for example in the form of a cache. This facilitates independent operation of the processing 
elements. Alternatively, or in addition to the own local instruction memory, the processing 
elements may share a global memory. 

25 



These and other aspects are described in more detail with reference to the 

drawings. 

Therein: 

30 Figure 1 schematically shows a processor system according to the invention, 

Figure 2 shows an example of a processing element in more detail 
Figure 3 shows an example of a cluster of 4 processing coupled to a channel 
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Figure 4 shows a reconfigurable channel infrastructure in a first embodiment 

of the processing system, 

Figure 5 shows a reconfigurable channel infrastructure in a second 

embodiment of the processing system, 
5 Figure 6 shows a more detailed implementation of the processing system of 

Figure 5, 

Figure 7 shows a reconfigurable channel infrastructure in a third embodiment 

of the processing system, 

Figure 8 shows several configurations of a processing system according to the 

10 invention. 



Figure 1 schematically shows a processor system according to the invention. 
The processor system comprises a plurality of processing elements PE U , ... PEi, n ; PE2,i, ... 

15 PE^PEW, . . . PE^. The processing elements can exchange data via data-path connections 
DPC. hi the preferred embodiment shown in Figure 1, the processing elements are arranged 
on a rectangular grid, and the data-path connections provide for data exchange between 
neighbouring processing elements. Non-neighbouring processing elements may exchange 
data by transferring it via a chain of muraafiy-neighbouring processing elements. 

20 Alternatively, or in addition, the processor system may comprise one or more global busses 
spanning sub-sets of the processing elements, or point-to-point connections between any pair 

of processing elements. 

Figure 2 shows an example of a processing element in more detail. Each 
processing element comprises one or more operation issue slots (ISs), each issue slot 
25 comprising one or more functional units (FUs). The processing element in Figure 2 

comprises five issue slots IS1-IS5, and six FUs: Two arithmetic and logic units (ALU), two 
multiply-accumulate units (MAC), an apphcation-specific unit (ASU), and a load/store unit 
(LD/ST) associated to a data memory (RAM). Issue slot IS1 comprises two FUs: An ALU 
and a MAC. FUs in a common issue slot share read ports from a register file and write ports 
to an interconnect network IN. In an alternative embodiment, a second interconnect network 
could be used in between register files and operation issue slots. The functional unit(s) in an 
issue slot have access to at least one register file associated to said issue slot In Figure 2, 
there is one register file associated to each issue slot. Alternatively, more than one issue slot 
could be connected to a single register file. Yet another possibility is that multiple, 
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independent register files are connected to a single issue slot (e.g. one different RF for each 
separate read port of an FU in the issue slot). The data-path connections DPC between 
different PEs are also connectedrtorthe interconnect networks IN of the respective PEs^-The-- 
FUs are controlled by a controller CT which has access to an instruction memory IM. A 
5 program counter PC determines the current instruction address in the instruction memory IM. 
The instruction pointed to by said current address is first loaded into an internal instruction 
register IR in the controller. The controller then controls data-path elements (function units, 
register files, interconnect network) to perform the operations specified by the instruction 
stored in the instruction register IR. To do so, the controller communicates to the functional 

10 units via an opcode-bus OB (e.g. providing opcodes to the function units), to the register files 
via an address-bus AB (e.g. providing addresses for reading and writing registers in the 
register file), and to the interconnect network IN through a routing-bus RB (e.g. providing 
routing information to the interconnect multiplexers). The controller has an input for 
receiving a cluster operation control signal C. This control signal C causes a guarded 

15 instruction, e.g. a conditional jump, to be carried out. The controller also has an output for 
providing an operation control signal F to other processing elements. This will be described 
in more detail in the sequel. 

Figure 3 shows an example wherein a cluster of 4 processing elements PEi, 
PE 4 , forming part of the processor shown in Figure 1, and having a more detailed architecture 

20 as shown in Figure 2, are coupled to a channel CH. Each of the processing elements can 

provide an operation control signal Fi, F4 to the channel CH. The channel returns a cluster 
operation control signal C being equal to Fi OR F 2 OR F3 OR F 4 . Hence, if any of the 
processing elements PEj in the cluster activates its operation control signal Fj, then each of 
the processing elements receives an activated cluster operation control signal. This causes 

25 each of the processing elements PEi, PE 4 to execute their guarded operations in the same 
way as the processor PEj. A particular example of a guarded operation is a conditional jump. 
The cluster operation control signal enables the processing elements PEi, ... , PE 4 to perform 
program execution in a lock-step mode, also in case of conditional jumps. In this way, 
instruction level parallelism may be exploited in that the program counter of both processing 

30 elements operate in a coupled mode. This has the result that the processing elements fetch 
instructions from corresponding addresses, i.e. possibly different physical addresses in the 
instruction memory which, nevertheless, comprise PE instructions which belong together in a 
coherent VLIW instruction. In this case, we say the different physical addresses correspond 
to the same logical address, In the same way, the cluster operation control signal may be used 
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to control other conditional or guarded operations. In a preferred embodiment shown, the 
processing elements have a separate output for broadcasting their own operation control 
— signal F and for monitoring the cluster operation control signal C. Alternatively, it is possible 
to apply apull-down mechanism, wherein each of the processing elements can pull down the 
5 cluster operation control signal C. In that case, only one terminal is required. 

The cluster operation control signal C is cluster-specific. Different clusters in 
the processor will have different and independent control signals C. To evaluate the cluster 
operation control signal for a given cluster, the channel should perform a logic OR operation 
of the operation control signals F of the PEs belonging to said cluster, but should ignore all 
10 operation control signals coming from PEs not belonging to said cluster. This way, the 
processor must comprise a reconfigurable channel infrastructure, so to allow for the 
formation of multiple and different clusters in the processor, each cluster is associated to a 

different cluster channel. 

Figure 4 shows, by way of example, how a processor comprising 7 processing 

elements PE, PE 7 can be configured using a reconfigurable channel infrastructure having 

programmable sum-terms, such as PLAs. In the example shown, a first task unit is formed by 
the cluster of processing elements PE* and PE*. A second task unit comprises the cluster of 
processing elements PE 3 , PE 4 , PE 5 , PE 6 , and a third task unit comprises a single processing 
element PEy. Any other configuration can easily be programmed by setting (indicated as "x»s 
20 in Figure 4) the programmable sum-terms. 

Although the embodiment of the processor shown in Figure 4 can be 
programmably reconfigured into independently operating task units, it has the disadvantage 
that each sum-term is spread across file entire controller array, being connected to every 
single one of the controllers. When the number of controllers is large, this could translate into 
25 very large and slow sum-terms. Moreover, the delay of a cluster channel (i.e. the time it takes 
to produce «C" after receiving all «F"s) will be dependent on the size of the total controller 
array, and not on the size of the cluster itself. Finally, the solution proposed in Figure 4 also 
has many redundancies. Note, for instance, that four sum-terms are required to implement the 
channel in Figure 3. The output of each of the four sum-terms is identical to the outputs of 
30 the other three sum-terms. Therefore, in principle, only one sum-term should suffice to 
implement said cluster channel, while the proposed solution will require 4 times larger 
hardware. 

Figure 5 shows an improved embodiment By way of example, a first and a 
secondprocessing element PEj and PEj +1 are shown, forming part of aplurality of processing 
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elements. The processing elements PEj and PEj+i are coupled to a reconfigurable channel 
infrastructure comprising a control chain CHN, and combination elements CEj, CBj+i for 
each of the processing elements. The control chain CHN'cdntrcJls the transmission of a 
intermediate control signals in two directions, i.e. from a processing element PBj to its 
5 succeeding processing elements PEj+i, ... and from a processing element PEj+i to its 
preceding processing elements PEj, ... . To that end, the control chain CHN comprises 
combination elements Cj,i and for each processing element PEj and a switch SWj j+i 
between each pair of neighbouring elements PEj, PEj+i. The combination element Cj,i 
combines an intermediate control signal LI, generated by the combination of the operation 

10 control signals Fj-i, Fj. 2 , . . . of the preceding processing elements PEj.i, PEj. 2 , . . respectively, 
with the operation control signal Fj of the processing element Pj, and provides the combined 
signal to the switch SWjj+i. Depending on the value of the configuration signal Ejj+i, said 
combined signal is further transmitted to the succeeding processing element Pj+i. In an 
analogous way, the combination element combines an intermediate control signal L2, 

1 5 generated by the combination of the operation control signals Fj+i, Fj+ 2 , ... of the proceeding 
processing elements PEj+i, PEj+2, • • •> respectively, controllably passed by the switch SWjj+i, 
with the operation control signal Fj of the processing element Pj, and provides the combined 
signal to the preceding switch SWj-ij. The combination element CEj provides the processing 
element PEj an active cluster operation control signal if the signal Fj (produced by its own 

20 output) or one of the intermediate control signals LI, L2, is activated. 

In the preferred embodiment shown in Figure 6, the combination elements Cj,i 
and C,^ , as well as CEj, CEj+i, are implemented as OR-gates, and the switch SWjj+i 
comprises AND gates. However, other types of logic gates may be used depending on the 
values assigned to the different signal states. If, for example, the active state of the operation 

25 control signal F and the cluster operation control signal C is assigned a value 0, instead of 1, 
then OR-gates are to be replaced by AND-gates and vice versa. Alternatively, a ternary or n- 
ary signal may be used to indicate the state of these control signals, requiring other logic 
gates. In yet another embodiment, the channel may use a pull-down or pull-up mechanism. 
The configuration signals Ejj+i are preferably provided by configuration memory elements. 

30 The configuration value stored therein may be provided by an external configuration bus, or 
by a separate configuration processor, or even by the processing elements themselves. 
Alternatively, the configuration values can be directly provided to the switches, instead of via 
a configuration memory. Preferably a set of memory cells used to program the switches is 
organized as a data-word in a memory. In an embodiment the memory may contain multiple 
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data-words each containing a different configuration. Therein the programmable switches can 
be programmed by selecting one of these data-words. For example one or more of the 
processing-elements can program the programmable switches by dynamically selecting the 
data-word in memory. 

5 The architecture according to Figure 5 can easily be extended to more 

dimensions, as is shown in Figure 7 for a processor having processing elements arranged in a 
2 dimensional grid. The implementation of the combination elements and the switches can be 
analogous to that of Figure 6. For clarity, only one processing element PEy, including 
associated circuitry for generating the cluster operation control signal C, is shown, but it will 
10 be clear to the skilled person that an arbitrary number of processing elements can be 

connected. In the embodiment of Figure 7 the channel infrastructure comprises mutually 
transverse chains (CHNy.H, CHNy,v). More in particular theassociated circuitry comprises a 
•horizontal' chain CHNy,H to control a clustering of the processing element PEy with other 
processing elements succeeding or preceding it in a horizontal direction. It further comprises 
15 a 'vertical' chain CHNy.v to control a clustering of the processing element PEj j with other 
processing elements succeeding or preceding it in a vertical direction. It is remarked that the 
wordings 'horizontal' and 'vertical' should be interpreted as any pair of orthogonal 
directions. 

The switching element SWij-i :i j, of the horizontal chain CHNy, H , controllably 
20 passes an input signal generated by one of the preceding processing element coupled to that 
chain as an intermediate control signal to the combination element Cy,i, which transmits an 
intermediate control signal to succeeding parts of the chain CHNyjH. Likewise, the switching 
element SWy^i of that chain CHNy,H controllably passes a input signal generated by one of 
the succeeding processing elements coupled to that chain as an intermediate control signal to 
25 the combination element C, j, 2 , which transmits an intermediate control signal to preceding 
parts of the chain CHNy^. Analogously, intermediate control signals are controllably 
transmitted by the vertical chain CHNy.v in a direction transverse to that of the horizontal 
chain CHNy, H . hi addition, the intermediate control signals LI, L2, transmitted through the 
horizontal chain CHNyji, are forwarded to the combination elements Qj, 3, Q. j.4 in the 
30 vertical chain CHNy.v. Analogously, the intermediate control signals L3, L4, transmitted 

through the vertical chain CHNy.v, are forwarded to the combination elements Q,j, u Q,j f2 in 
the horizontal chain CHNy, H . This allows for the formation of «L"-shaped and arbitrary 
rectangular clusters. The combination element CEy combines the intermediate control signals 
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LI, L2, L3 and L4 with the operation control signal provided by the processing element PEy 
itself and provides the cluster operation control signal C to that processing element PEy . 

It isnoted-thafrthe logical functions of the combination element-GEi-j and the 
combination elements Ci j,l and Ci j,2 can be cross-optimised. More specifically: 
5 Ci j,l computes: F OR L3 OR L4 OR LI 

Cij,2 computes: F OR L3 OR L4 OR L2 
CEi j computes: F OR LI OR L2 OR L3 OR L4 

So in a hardware implementation, the logic of all three combiners (CE and the 
two C f s) can be cross-minimized, i.e. gates can be re-used across different combiners. In 

10 essence, all basic operations done in the combination element CE are already done in the Cs, 
so CE is just a conceptual block (fundamental, nevertheless!). The same rationale applies for 
the vertical channel. So the logic of all 5 combiners (one CE and four Cs) in Figure 7 can be 
minimized through gate re-use across combiners. For the purpose of clarity however the 
combination element CEi j is shown in Figure 7 as a separate function.The skilled person will 

1 5 see that pipeline registers can be inserted in different points of the reconfigurable channel 
infrastructure to reduce signal propagation delay, to remove loops in the logic, or any other 
purpose, as long as the corresponding added cycles are taken into account in the 
programming of the processing elements. 

It will also be clear to the skilled person that the possibilities for forming 

20 clusters by programming the switches in the proposed reconfigurable channel infrastructure 
are numerous and growing exponentially with the number of processing elements available. 

By way of example this is illustrated in Figures 8a to 8d for a processing 
system comprising 4 processing elements which are arranged in a rectangle. In Figure 8a the 
processing elements are operating independently of each other. It is assumed that the 

25 switches for selectively transmitting control signals are arranged between the nearest 

neighbours. Hence a diagonal transmission of the control signals from for example PE1 to 
PE3 is not allowed, although the control signals may be transmitted via PE2 or PE4. This is 
however not a strict requirement. Basically the channel infrastructure may extend between 
any pair of processing elements, but for layout purposes the channel infra structure is 

30 preferably composed from controllable connections between pairs of neighbouring 
processing elements. 

Figure 8b shows the four possible ways in this case to configure the processing 
system as three task units. A bar between two processing elements indicates that these 
processing elements are joined into a cluster. 
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Figure 8c shows the six possible ways to configure the processing system as 

six task units. 

Figure 8c shows-a-the configuration of the processing system wherein all 

processing elements are clustered into a single task unit 

5 It is remarked that the scope of protection of the invention is not restricted to 

the embodiments described herein. It will be clear to the skilled person that logic functions 
can be implemented in a plurality of ways. For example instead of performing a logical OR 
function on active high signals a logic AND function can be applied to active low signals. 
Alternatively these functions could be implemented by a pull down mechanism or by a 

10 lookup table. Neither is the scope of protection of the invention restricted by the reference 
numerals in the claims. The word •comprising' does not exclude other parts than those 
mentioned in a claim. The word 'aCn)' preceding an element does not exclude aplurality of 
those elements. Means forming part of the invention may both be implemented in the form of 
dedicated hardware or in the form of a programmed general purpose processor. The invention 

15 resides in each new feature or combination of features. 
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CLAIMS: 
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1. 



A processing system comprising a plurality of processing element, the 



processing elements comprising a controller and computation means, the plurality of 
processing elements being dynamically reconfigurable as mutually independently operating 
task units which task units comprise one processing element or a cluster of two or more 
5 processing elements ,the processing elements within a cluster being arranged to execute 
instructions under a common thread of program control. 

2. Processing system according to claim 1, wherein processing elements 
organized in a task unit share at least one common control signal for controlling instruction 

10 execution. 

3. Processing system according to claim 2, wherein the common control signal is 
a flag controlling a guarded operation* 

15 4. Processing system according to claim 3, wherein the guarded operation is a 

conditional jump. 

5. Processing system according to any of the preceding claims, wherein the 

processing elements are connected to each other via data-path connections (DPC). 



20 



6. Processing system according to claim 5, wherein the data-path connections 

(DPC) are limited to neighbour-to-neighbour connections. 



25 



7. Processing system according to any of the preceding claims, wherein the 

common control signal is derived from intermediate control signals transmitted through a 
reconfigurable channel infrastructure connected to the processing elements. 
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8. Processing system according to claim 7, wherein the common control signal is 
derived by combining Ihe intermediate control signals through a combination element 

"associated to each processing element 

9. Processing system according to claim 8, wherein the combination elements 
consist of OR-gates. 

10. Processing system according to claim 7, wherein the channel infrastructure 
comprises programmable sum-terms. 

1 1 . Processing system according to claim 7, wherein the channel infrastructure 
comprises programmable product-terms. 

12. Processing system according to claim 7, wherein the channel infrastructure 
comprises mutually transverse chains. 

13. Processing system according to claim 12, wherein Ihe intermediate control 
signals transmitted through chains having a first orientation are forwarded to the 
combination elements in chains having a second orientation. 

14. Processing system according to claims 13, wherein the intermediate control 
signals transmitted through the chains having the second orientation are forwarded to the 
combination elements in the chains having the first orientation. 

15. Processing system according to claims 7 or 12, wherein the channel 
infrastructure comprises combination elements for combining an intermediate control signal 
transmitted through the channel infrastructure with an operation control signal of associated 
processing elements, and programmable switches between pairs of processing elements, for 
locally controllably inhibiting transmission of intermediate control signals. 



16. Processing system according to claim 15, wherein the combination elements 

consist of OR-gates. 
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17. Processing system according to claim 15, wherein the programmable switches 
comprise AND-gates. ' 

18. Processing system according to claims 15, 16, or 17, wherein the 
5 programmable switches are programmed by signals stored in memory cells. 

19. Processing system according to claim 18, wherein at least one of the 
processing elements can write to at least one of the memory cells. 

10 20. Processing system according to claim 1 8, wherein a set of memory cells used 

to program the switches is organized as a data-word in a memory. 

21 . Processing system according to claim 20, wherein the memory contains 
multiple data-words, and wherein the programmable switches are programmed by selecting 

1 5 one of these data-words. 

22. Processing system according to claims 21, wherein one or more of the 
processing elements can program the programmable switches by dynamically selecting the 
data-word in memory. 

20 

23. Processing system according to claims 18, 19, 20, 21, or 22, the memory 
consisting of volatile random access memory (RAM). 

24. Processing system according to any of the preceding claims, wherein the 
25 processing elements comprise VLIW processors. 

25. Processing system according to claim 24, wherein the VLIW processors 
comprise an internal interconnect network (IN). 

30 26. Processing system according to claim 25, wherein the interconnect network 

(IN) consists of point-to-point connections. 

27. Processing system according to claims 25 or 26, wherein the interconnect 

network (IN) comprises data-path connections (DPC) going across processing elements. 
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28. Processing system according to any of the preceding claims, wherein the 
processing elements are~arranged in a2-dimensional grid. 

29. Method for operating a processing system comprising a plurality of processing 
elements, the processing elements comprising a controller and computation means, according 
to which method the plurality of processing elements are dynamically reconfigured as 
mutually independently operating task units, which task units comprise one processing 
element or a cluster of two or more processing elements, wherein the processing elements 
within a cluster execute instructions under a common thread of program control. 
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A processing system according to the invention comprises a plurality of 
processing elements (PE\,...J?Et). The processing elements comprise a controller and 
computation means. The plurality of processing elements is dynamically reconfigurable as 
mutually independently operating task units (TUl, TU2, TU3), which task units comprise 
5 one processing element (PEy) or a cluster of two or more processing elements (PE 3 , PE 4 , PE 5> 
PE6>. The processing elements within a cluster are arranged to execute instructions under a 
common thread of program control. In this way the processing system is capable of using the 
same sub-set of data-path elements to exploit instruction level parallelism or task level 
parallelism or a combination thereof, dependent on the application. 
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